A Knex little more typed factory of SQL query builder powed by TypeScript,
with auto-generated type-safe tables accessor for Node.js".
Installation
npm install kmore knex
npm install pg
npm install mssql
npm install oracle
npm install sqlite3
Usage
Build configuration:
Ensure sourceMap
or inlineSourceMap
is true in the tsconfig.json
{
"compilerOptions": {
"sourceMap": true
},
}
Create connection
import { Config } from 'kmore'
export const config: Config = {
client: 'pg',
connection: {
host: 'localhost',
user: 'postgres',
password: 'foo',
database: 'db_ci_test',
},
}
export interface TbListModel {
tb_user: User
tb_user_detail: UserDetail
}
export interface User {
uid: number
name: string
ctime: Date | 'now()'
}
export interface UserDetail {
uid: number
age: number
address: string
}
const db = kmore<TbListModel>({ config })
const kTables = genTbListFromType<TbListModel>()
const db = kmore<TbListModel>({ config }, kTables)
Create tables with instance of knex
await db.dbh.schema
.createTable('tb_user', (tb) => {
tb.increments('uid')
tb.string('name', 30)
tb.timestamp('ctime', { useTz: false })
})
.createTable('tb_user_detail', (tb) => {
tb.integer('uid')
tb.foreign('uid')
.references('tb_user.uid')
.onDelete('CASCADE')
.onUpdate('CASCADE')
tb.integer('age')
tb.string('address', 255)
})
.catch((err: Error) => {
assert(false, err.message)
})
Inert rows via auto generated table accessor
const { tb_user, tb_user_detail } = db.rb
await tb_user()
.insert([
{ name: 'user1', ctime: new Date() },
{ name: 'user2', ctime: 'now()' },
])
.then()
await tb_user_detail()
.insert([
{ uid: 1, age: 10, address: 'address1' },
{ uid: 2, age: 10, address: 'address1' },
])
.returning('*')
.then()
Join tables
const { tables: t, rb, scopedColumns: sc } = db
await rb.tb_user<UserDetail>()
.select()
.innerJoin(
t.tb_user_detail,
sc.tb_user.uid,
sc.tb_user_detail.uid,
)
.where(sc.tb_user.uid, 1)
.then((rows) => {
const [row] = rows
assert(row && row.uid)
assert(row && row.name)
assert(row && row.age)
return rows
})
Use instance of knex
await db.dbh.raw(`DROP TABLE IF EXISTS "${tb}" CASCADE;`).then()
await db.dbh.destroy()
Demo
Packages
kmore is comprised of many specialized packages.
This repository contains all these packages. Below you will find a summary of each package.
License
MIT
Languages